MLOCK(2) | 리눅스 프로그래머 매뉴얼 | MLOCK(2) |
이름¶
mlock - 메모리의 일정 영역에 대한 페이징을 금지시킨다.
사용법¶
#include <sys/mman.h> int mlock(const void *addr, size_t len);
설명¶
mlock은 addr부터 len 바이트 만큼의 메모리에 대한 페이징을 금지시킨다. 지정된 메모리 범위의 일부를 포함하는 모든 페이지들은 mlock 시스템 콜이 성공했을 때 RAM에 상주하는 것이 보장된다. 그리고 이 페이지들은 munlock이나 munlockall에 의해 잠금이 풀릴 때까지 또는 프로세스가 종료할 때까지 또는 exec에 의해 다른 프로그램이 시작할 때까지 RAM에 상주하는 것이 보장된다. fork에 의한 자식 프로세스는 페이지 잠금을 상속받지 않는다.
메모리 잠금은 주로 두 가지 경우에 응용된다: 실시간 알고리즘과 high-security 데이타 처리. 실시간 응용프로그램의 경우는 결정론적인 타이밍과 스케줄링 같은 것이 요구되는데, 이 때 페이징은 예상치 못한 프로그램 실행 지연을 야기하는 주요 원인이다. 또한 실시간 응용프로그램은 보통 sched_setscheduler로 실시간 스케쥴러를 사용한다. 암호 보안 소프트웨어는 데이터로 암호나 보안키 같은 중요 바이트를 처리한다. 페이징 결과, 이 데이터가 지속적인 스왑 저장 장치에 저장되며 보안 소프트웨어가 RAM에서 이 데이터를 지우고 끝난 후에도 오랫동안 외부에 노출될 수 있다.
메모리 잠근은 스택이 아니다. 즉, mlock이나 mlockall이 여러번 호출되어 여러번 잠겼던 페이지는 상응하는 범위에 대한 munlock이나 munlockall를 단 한번 호출하여 잠금을 풀 수 있다. 여러 위치나 여러 프로세스에 의해 잠겨진 페이지는 적어도 하나의 위치나 프로세스에 의해 잠겨져 있는 한 RAM에서 계속적으로 잠금이 유지된다.
mlock과 munlock를 이용할 수 있는 POSIX 시스템에서 _POSIX_MEMLOCK_RANGE는 <unistd.h>에 정의되어 있으며 <limits.h>에서 PAGESIZE는 페이지당 바이트 수를 가리킨다.
반환값¶
성공시, mlock은 0을 리턴한다. 에러시, -1이 리턴되며, errno는 적절한 값으로 설정된다. 그리고 해당 프로세스의 주소 공간의 잠금에 어떠한 변화도 일어나지 않는다.
에러¶
호환¶
POSIX.1b, SVr4. SVr4는 EAGAIN 에러 조건을 추가적으로 기술한다.
관련 항목¶
역자¶
정강훈 <skyeyes@soback.kornet.net>, 2000년 5월 20일
1995년 11월 26일 | 리눅스 1.3.43 |